草庐IT

java - jUnit 忽略来自基类的@Test 方法

全部标签

ruby-on-rails - 在 Ruby 中运行 eval 有安全的方法吗?

我们正在开发一种与Tropo具有类似要求的产品(参见https://github.com/tropo/tropo-samples/tree/master/ruby),允许用户编写一个ruby​​脚本,该脚本可以访问传入的一些函数和变量。但是,我们希望避免用户访问全局调用删除所有用户或终止程序。有没有办法用eval来完成这个? 最佳答案 这在很大程度上取决于您如何实现它,但请研究绑定(bind)与eval的使用。通过创建您自己的绑定(bind)并使用“安全”对象预加载它,您可以限制用户可以使用他的代码执行的操作。http://rdoc

ruby - Rails 3 db :migrate 的未定义方法 `visitor'

我在Rails3中进行数据库迁移时遇到异常。undefinedmethod`visitor'for#编辑请查看解决方案here.在我的项目中没有出现字符串visitor所以我很困惑。这是完整的转储:$rakedb:migrate--trace**Invokedb:migrate(first_time)**Invokeenvironment(first_time)**Executeenvironment**Invokedb:load_config(first_time)**Invokerails_env(first_time)**Executerails_env**Executedb:l

ruby - 如何调试被静默忽略的插件?

这里是Jekyll的新手(之前在Hyde上)。位于_plugins/目录中的Ruby文件显然被默默地忽略了。我在Ubuntu12.04上使用0.11.2版的Jekyll和ruby​​1.8.7。是否应该添加一个额外的配置参数来加载这些插件?文档没有这么说-理智的默认设置应该是查看_plugins,并且应该自动要求它们。如何调试Jekyll插件的加载? 最佳答案 对于我的jekyll实例(也是0.11.2,但在Mac上使用ruby​​1.9.2p290),我不需要添加任何额外的配置,但您可以尝试将以下行添加到您的顶级“_config”

ruby - RSpec 规范伪造类常量的最佳实践或解决方法

假设我有Car和Mechanic类(class)。汽车有“运行”方法。Mechanic出于某种原因需要Car。然后我编写RSpec规范。在mechanic中,我定义了一个这样的假类:classCar;end然后将mechanic在其上使用的方法stub。如果我单独运行测试,一切正常。但是当我一起运行两个测试时(rspecspec/directory/),我的Mechanicspecs使用真实的Car类。所以。我想这是因为ruby​​类是“开放的”,我已经为汽车规范加载了一次类。但是有更好的方法吗?这种情况的最佳做法是什么?这是否意味着我的代码需要一些改进,因为它可能是紧密耦合的?我在g

ruby - 在 ruby​​ 中模拟 3rd 方对象的最佳方法是什么?

我正在使用twittergem编写一个测试应用程序,我想编写一个集成测试,但我不知道如何模拟Twitter命名空间中的对象。这是我要测试的功能:defbuild_twitter(omniauth)Twitter.configuredo|config|config.consumer_key=TWITTER_KEYconfig.consumer_secret=TWITTER_SECRETconfig.oauth_token=omniauth['credentials']['token']config.oauth_token_secret=omniauth['credentials']['s

sql - 来自 ActiveRecord::Base.connection.execute(sql) - PostgreSQL 的结果

在使用ActiveRecord::BaseConnection类执行SQL语句后,如何找到PostgreSQL处理的记录数?temp_sql="UPDATEtable_aSETcolumn_a='abc'WHEREcolumn_b=1"result=ActiveRecord::Base.establish_connection(@db).connection.execute(temp_sql)或者您可以建议更好的方法来做到这一点。请记住,上面的更新声明是一个简单的更新声明,以保持问题简短。我真正的查询是“基于集合”的,涉及复杂的创建临时表、更新、插入语句。

ruby - 来自 IntelliJ 的 Runnin rspec

我通常从IntelliJ内部运行我的规范。我已经删除了我的gem并使用bundleinstall重新安装它们(由于另一个错误),现在我在尝试运行规范时遇到错误。我注意到从它使用的intelliJ运行规范:from/home/user/.rvm/rubies/ruby-2.2.4/lib/ruby/site_ruby/2.2.0/rubygems/core_ext/kernel_require.rb:54:in`require'从shell运行时情况并非如此(我在kernel_require脚本中放置了一个print检查它)。我还看到来自intelliJ的ruby​​版本是:"ruby2

ruby - 真正的 sinatra(ruby/rack) after_filter 最快的方法是什么?

好的,这是一个简单的任务。在我向客户端呈现html之后,我想使用请求中的信息执行数据库调用。我正在使用sinatra,因为它是一个轻量级的微框架,但我真的支持ruby​​中的任何东西,如果它更快/更容易(Rack?)。我只想获取url并根据url将客户端重定向到其他地方。那么如何使用rack/sinatra作为一个真正的after_filter。after_filter我的意思是在响应发送到客户端之后。还是没有线程就无法实现?我fork了sinatra并在过滤器之后添加,但是没有办法刷新响应,即使是假设流式传输文件(显然是二进制文件)的send_data也在等待after_filter

ruby - 是否有一种直接的包罗万象的方法来记录在 Ruby 中的对象上调用的方法?

有没有一种快速的方法来跟踪在对象上调用的方法?通常,当我在gem的公共(public)界面之下的级别上工作时,我会遇到难以追踪的错误。最终,我最终通过源代码跟踪对象并将所有内容都记在脑海中。但是,如果能够在对象上调用类似#log_method_calls的东西,那么,比如说,调用它的所有方法都会打印到stdout或其他东西。有什么办法可以做到这一点? 最佳答案 有几种方法可以做到这一点,视情况而定。如果可以创建一个新对象而不是被观察对象,您可以使用method_missing轻松编写一个观察者类。classLogProxydefin

ruby - 为什么 block 不像方法那样继承调用者的 $SAFE 级别?

当$SAFE=4的线程调用方法时,该方法以相同的$SAFE级别运行:deftest_methodraise"valueof$SAFEinsidethemethod:#{$SAFE}"endt=Thread.new{$SAFE=4;self.test_method};t.join=>RuntimeError:valueof$SAFEinsidethemethod:4但是,当一个block被调用时,它似乎使用了来自其原始上下文的$SAFE:test_lambda=lambdadoraise"valueof$SAFEinsidethelambda:#{$SAFE}"endt=Thread.n